热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python正则表达式详解:掌握数量词用法轻松上手

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Python正则表达式(一看就懂)相关的知识,希望对你有一定的参考价值。 目录 哈喽O(∩_∩)O😄 什么是正则表达式(⊙_⊙) 简

篇首语:本文由编程笔记#小编为大家整理,主要介绍了Python正则表达式(一看就懂)相关的知识,希望对你有一定的参考价值。


目录

哈喽O(∩_∩)O😄

什么是正则表达式(⊙_⊙)

简单说,正则表达式是…

正则表达式怎么用❓

sreach的用法🍊

匹配连续的多个数值🍉

 字符"+"重复前面一个匹配字符一次或者多次🍉

字符"*"重复前面一个匹配字符零次或者多次🍉

字符"?"重复前面一个匹配字符零次或者一次🍉

特殊字符使用反斜杠"“引导,例如”\\r"、"\\n"、"\\t"、"\\"分别表示回车、换行、制表符号与反斜线自己本身

 完整表🔍

 match用法🤔

match用法😃

 match对象🍊

数量词🍊

匹配开头、结尾🍊

 匹配分组🔍

match总结😄

实践出真知 凸(`0´)凸 ☀️

写在最后🧐





哈喽O(∩_∩)O😄

今天来发一下python正则表达式,其实这个也是比较简单的

肝了好几个小时才写出来呀


什么是正则表达式(⊙_⊙)

目前越来越多的网站、编辑器、编程语言都已支持一种叫“正则表达式”的字符串查找“公式”,有过编程经验的同学都应该了解正则表达式(Regular Expression 简写regex)是什么东西,它是一种字符串匹配的模式(pattern),更像是一种逻辑公式。


简单说,正则表达式是…

python中必备的工具,主要是用来查找和匹配字符串的。

正则表达式尤其在python爬虫上用的多。


正则表达式怎么用❓

首先,我们要导入头文件(写c++写习惯了)模块

import re

因为re是内置模块,所以不需要额外安装,就很银杏


sreach的用法🍊


匹配连续的多个数值🍉


import re
r=r"\\d+"
m=re.search(r,"YRYR567eruwgf")#目标是567
print(m)

re模块中,r“\\d+”正则表达式表示匹配连续的多个数值,search是re中的函数,从"YRYR567eruwgf"字符串中搜索连续的数值,得到"567"

结果:

可以看到,搜索到了连续值“567”


 字符"+"重复前面一个匹配字符一次或者多次🍉

import re
r=r"b\\d+"
m=re.search(r,"a12b1233cd")
print(m)

 这样,结果就是b后面的连续数字

结果:


字符"*"重复前面一个匹配字符零次或者多次🍉

“*" 与 "+"类似,但有区别,列如:
可见 r"ab+“匹配的是"ab”,但是r"ab
 “匹配的是"a”,因为表示"b"可以重复零次,但是”+“却要求"b"重复一次以上

import re
r=r"ab+"
m=re.search(r,"acabc")
print(m)
r=r"ab*"
m=re.search(r,"acabc")
print(m)

 结果:


字符"?"重复前面一个匹配字符零次或者一次🍉

匹配结果"ab”,重复b一次 

import re
r=r"ab?"
m=re.search(r,"abbcabc")
print(m)

 结果:


特殊字符使用反斜杠"“引导,例如”\\r"、"\\n"、"\\t"、"\\"分别表示回车、换行、制表符号与反斜线自己本身


import re
r=r"a\\nb"
m=re.search(r,"ca\\nbcaba")
print(m)

 结果:


 完整表🔍

其实上面说这些都是比较基础,比较简单的,还有复杂一点的,都在这张表里


 match用法🤔


match用法😃

语法:re.match(pattern, string[, flags])  

从首字母开始开始匹配,string如果包含pattern子串,则匹配成功,返回Match对象,失败则返回None,若要完全匹配,pattern要以$结尾。

#示例:
name='张三'
if re.match('张\\w+',name):
print(',你好!'.format(name))
# 张三,你好!

输出结果:张三,你好

张三:谁叫我?

不开玩笑了,继续

总的来说,match就是


  • 返回匹配的match对象
  • 默认从给定字符串的开头开始匹配、即使正则表达式没有用^声明匹配开头

 match对象🍊

Match对象的几个属性: 

注意,前面是有“.”的
1..string 待匹配的文本
2..re 匹配使用的pattern对象
3..pos 正则表达式搜索文本的开始位置
4..endpos 正则表达式搜索文本的结束位置
Match对象的几个方法: 
1.group(0) 返回匹配到的子串
2.start() 返回匹配子串的开始位置
3.end() 返回匹配子串的结束位置
4.span() 返回start()、end()


数量词🍊


匹配开头、结尾🍊



 匹配分组🔍

好了,看了上面几张表,其实我觉得最重要的在下面  


match总结😄

其实没啥好总结的,但你要看懂这张图,这个很重要

 我框出来的是我自己感觉经常用的

其实我自己刚学的时候也听不懂,现在觉得可简单了

所以,你应该现在就觉得很简单吧?

但是,正则表达式的字符很多,容易记混,一不小心就好几十个报错,很让人崩溃


实践出真知 凸(`0´)凸 ☀️

学了这么多,是不是想撸个程序了?

已经给你准备好了

程序效果:输入手机号,通过正则表达式判断手机号合不合法,

如果合法,就输出这个手机号的信息(所属地等)

如果不合法,就重新输入,简单吧?

这里我想重点说一下怎么获取手机号的信息

我一开始打算上网上百度一波的,没想到直接复制过来23个报错、我也是醉了

哎呀,不能再发表情包了


ε=(´ο`*)))唉,还是自己写吧、、、

我想起了有个模块叫phone,可以实现这个功能

但是你可能还没有安装这个模块,要按命令行模式下输入pip install phone

等个六六四十九秒就下载下来了

然后你就可以体验一下了

代码(PyCharm运行通过)

import phone
from time import *
import re
def begin():
print("欢迎来到查询小程序")
print("1.查询")
print("2.用户")
def p(n):
if re.match(r'1[3,4,5,7,8]\\d9', n):
if re.match(r'13[0,1,2]\\d8', n) or \\
re.match(r"15[5,6]\\d8", n) or \\
re.match(r"18[5,6]", n) or \\
re.match(r"145\\d8", n) or \\
re.match(r"176\\d8", n):
return True
elif re.match(r"13[4,5,6,7,8,9]\\d8", n) or \\
re.match(r"147\\d8|178\\d8", n) or \\
re.match(r"15[0,1,2,7,8,9]\\d8", n) or \\
re.match(r"18[2,3,4,7,8]\\d8", n):
return True
else:
return True
else:
return False
if __name__ == "__main__":
s=0
begin()
while True:
op = int(input("请输入:"))
if op==1:
phoneNum = str(input("请输入你的电话号码"))
if p(phoneNum)==False:
print("该手机号无效")
for i in range(100):
print('\\n')
begin()
else:
info = phone.Phone().find(phoneNum)
print("手机号码:"+str(info["phone"]))
print("手机所属地:"+str(info["province"])+"省"+str(info["city"])+"市")
print("邮政编号:"+str(info["zip_code"]))
print("区域号码:"+str(info["area_code"]))
print("手机类型:"+str(info["phone_type"]))
s+=1
i = input("输入任意数退出...")
for i in range(100):
print('\\n')
begin()
if op==2:
print("使用次数:"+str(s))
i = input("输入任意数退出...")
for i in range(100):
print('\\n')
begin()

写在最后🧐

感觉这次的博客好像比较长,你能看到这里,已经超越了60%的人了,如果有谁还不是很明白,或者有c++和python的问题,都可以私信我,我看到后会一一回复哦

另外,互粉必回💪

感谢您的阅读,拜拜!


推荐阅读
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了如何使用Python编写爬虫程序,从豆瓣电影Top250页面抓取电影信息。文章涵盖了从基础的网页请求到处理反爬虫机制,再到多页数据抓取的全过程,并提供了完整的代码示例。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 本文深入探讨了Python中的高阶函数和Lambda表达式的使用方法,结合实际案例解析其应用场景,帮助开发者更好地理解和运用这些强大的工具。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 使用Pandas高效读取SQL脚本中的数据
    本文详细介绍了如何利用Pandas直接读取和解析SQL脚本,提供了一种高效的数据处理方法。该方法适用于各种数据库导出的SQL脚本,并且能够显著提升数据导入的速度和效率。 ... [详细]
  • 本文详细解析了如何使用Python的urllib模块发起POST请求,并通过实例展示如何爬取百度翻译的翻译结果。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 在学习网页爬虫时,使用Selenium进行自动化操作。初次安装selenium模块后,第二天运行代码时遇到了ImportError:无法从'selenium'导入名称'webdriver'。本文将详细解释该问题的原因及解决方案。 ... [详细]
author-avatar
Mrheartheart
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有